//给定一个包括 n 个整数的数组 nums 和 一个目标值 target。找出 nums 中的三个整数，使得它们的和与 target 最接近。返回这三个数的和
//。假定每组输入只存在唯一答案。 
//
// 
//
// 示例： 
//
// 输入：nums = [-1,2,1,-4], target = 1
//输出：2
//解释：与 target 最接近的和是 2 (-1 + 2 + 1 = 2) 。
// 
//
// 
//
// 提示： 
//
// 
// 3 <= nums.length <= 10^3 
// -10^3 <= nums[i] <= 10^3 
// -10^4 <= target <= 10^4 
// 
// Related Topics 数组 双指针 排序 
// 👍 821 👎 0


import java.util.Arrays;

//leetcode submit region begin(Prohibit modification and deletion)
class Solution {
    public int threeSumClosest(int[] nums, int target) {
        Arrays.sort(nums);

        int sum , result =  nums[0] + nums[1] + nums[2];

        for (int i = 0; i < nums.length - 2 ; i++) {
            for (int j = i + 1 , k = nums.length - 1; j < k; ) {
                sum = nums[i] + nums[j] + nums[k];
                if (Math.abs(target - sum) < Math.abs(target-result)){{
                    result = sum;
                }}
                if ( sum > target){
                    k--;
                }else if (sum < target){
                    j++;
                }else {
                    return sum;
                }
            }

        }

        return result;

    }
}
//leetcode submit region end(Prohibit modification and deletion)
